Presto একটি ডিস্ট্রিবিউটেড SQL কোয়েরি ইঞ্জিন যা ডেটা বিশ্লেষণের জন্য ব্যাপকভাবে ব্যবহৃত হয়। যেহেতু Presto বিভিন্ন ডেটা সোর্সের সাথে সংযুক্ত হয় এবং বিভিন্ন ব্যবহারকারী এবং দলের জন্য ডেটা এক্সেস প্রদান করে, তাই Authentication (প্রমাণীকরণ) এবং Authorization (অনুমোদন) অত্যন্ত গুরুত্বপূর্ণ ভূমিকা পালন করে।
Presto-তে Authentication এবং Authorization ব্যবস্থাগুলি ব্যবহারকারীদের সুরক্ষিত এবং সঠিকভাবে ডেটা অ্যাক্সেস করতে সহায়ক। এই টিউটোরিয়ালে আমরা Presto তে Authentication এবং Authorization কনফিগারেশন নিয়ে আলোচনা করব।
Authentication হলো প্রক্রিয়া যার মাধ্যমে Presto সিস্টেম ব্যবহারকারীদের শনাক্ত করে এবং তাদের ডেটাবেস বা সার্ভারে অ্যাক্সেস দেওয়ার পূর্বে তাদের পরিচয় নিশ্চিত করে।
Presto তে প্রমাণীকরণের জন্য বিভিন্ন পদ্ধতি ব্যবহার করা যায়:
Presto-তে Basic Authentication ব্যবহার করে, ব্যবহারকারীরা তাদের ইউজারনেম এবং পাসওয়ার্ডের মাধ্যমে লগইন করতে পারে। এটি প্রাথমিকভাবে নিরাপত্তার জন্য ব্যবহৃত হয়।
কনফিগারেশন:
Presto-তে Basic Authentication চালু করতে etc/config.properties
ফাইলে নিম্নলিখিত সেটিং যোগ করতে হবে:
http-server.authentication.type=PASSWORD
http-server.authentication.password-authenticator-class=com.facebook.presto.security.PasswordAuthenticator
এটি Presto সার্ভারের প্রমাণীকরণের জন্য ইউজারনেম এবং পাসওয়ার্ড চেক করবে। PasswordAuthenticator ব্যবহারকারী নাম এবং পাসওয়ার্ড যাচাই করার জন্য উপযোগী।
Kerberos একটি নিরাপদ প্রমাণীকরণ প্রোটোকল যা ডিসট্রিবিউটেড সিস্টেমে সুরক্ষিত অ্যাক্সেস নিশ্চিত করে। এটি Presto তে নিরাপদ এবং স্কেলেবল প্রমাণীকরণের জন্য ব্যবহৃত হয়, বিশেষত বড় সংস্থাগুলিতে যেখানে উচ্চ নিরাপত্তা প্রয়োজন।
কনফিগারেশন:
Presto তে Kerberos প্রমাণীকরণ সক্ষম করতে নিম্নলিখিত পদ্ধতি অনুসরণ করুন:
krb5.conf
ফাইলটি সিস্টেমে সঠিকভাবে কনফিগার করা থাকতে হবে।Presto সার্ভারে Kerberos প্রমাণীকরণ চালু করাetc/config.properties
ফাইলে নিম্নলিখিত কনফিগারেশন যোগ করুন:
http-server.authentication.type=KERBEROS
http-server.authentication.krb5-config-file=/path/to/krb5.conf
kerberos.keytab
ফাইলের পাথ নির্ধারণ করতে হবে।Authorization হল প্রক্রিয়া যার মাধ্যমে নির্ধারণ করা হয় কোন ব্যবহারকারী কী ডেটা এবং কোণের উপর অ্যাক্সেস পেতে পারবে। এটি ব্যবহারকারীদের তাদের প্রয়োজনীয় অ্যাক্সেস প্রদান করে এবং সুরক্ষিত ডেটা ম্যানেজমেন্ট নিশ্চিত করে।
Presto-তে Authorization চালু করার জন্য কিছু পদ্ধতি রয়েছে:
Presto তে file-based authorization পদ্ধতি ব্যবহারকারীর ডেটা অ্যাক্সেস নিয়ন্ত্রণ করতে ব্যবহৃত হয়। এই পদ্ধতিতে একটি ফাইলের মাধ্যমে বিভিন্ন ইউজার গ্রুপ এবং তাদের অনুমোদিত ডেটা অ্যাক্সেস নির্ধারণ করা হয়।
কনফিগারেশন:
Presto-তে file-based authorization চালু করতে etc/config.properties
ফাইলে নিম্নলিখিত সেটিং যোগ করতে হবে:
http-server.security.enabled=true
http-server.security.authenticator=com.facebook.presto.security.authorization.FileBasedAccessControl
এটি Presto তে access-control.properties
ফাইল ব্যবহার করে ব্যবহারকারী এবং তার অনুমোদিত অ্যাক্সেস নির্ধারণ করে।
Row-level authorization ব্যবহারকারীদের শুধুমাত্র তাদের জন্য অনুমোদিত ডেটার অ্যাক্সেস প্রদান করে। এটি ব্যবহারকারীকে নির্দিষ্ট রেকর্ডের উপর অ্যাক্সেস দেয় এবং অন্য রেকর্ডের অ্যাক্সেস সীমাবদ্ধ করে।
কনফিগারেশন:
Row-level authorization চালু করার জন্য আপনাকে একটি কাস্টম authorization কনফিগারেশন ফাইল তৈরি করতে হবে, যেখানে আপনি অনুমোদিত ইউজারদের জন্য নির্দিষ্ট শর্তাবলী নির্ধারণ করতে পারেন।
http-server.security.row-level-authorization.enabled=true
Presto-তে Connector-level authorization ব্যবহৃত হয় ডেটাবেস কানেক্টরের উপর নির্দিষ্ট অ্যাক্সেস নিয়ন্ত্রণ করার জন্য। বিভিন্ন ডেটাবেস কানেক্টরের জন্য আলাদা আলাদা অনুমোদন কনফিগার করা যেতে পারে।
কনফিগারেশন:
connector.name=hive
hive.security=sql-standard
এটি Hive Connector এর জন্য SQL standard security ব্যবহার করবে, যার মধ্যে ইউজারের অনুমোদন যাচাই করা হবে।
Presto তে Authentication এবং Authorization ব্যবস্থাগুলি ব্যবহৃত হয় নিম্নলিখিত কার্যক্রমের জন্য:
Presto তে Authentication এবং Authorization ব্যবস্থাগুলি ডেটার নিরাপত্তা এবং সঠিক অ্যাক্সেস নিয়ন্ত্রণ নিশ্চিত করে। বিভিন্ন প্রমাণীকরণ পদ্ধতি যেমন Basic Authentication, Kerberos Authentication, এবং Authorization পদ্ধতি যেমন File-based Authorization, Row-level Authorization, এবং Connector-level Authorization ডেটাবেসের নিরাপত্তা বৃদ্ধি করে এবং ব্যবহারকারীদের তাদের অনুমোদিত ডেটার উপর অ্যাক্সেস দেয়।
Presto তে এই সুরক্ষা ব্যবস্থা কার্যকরভাবে ব্যবহার করে, আপনি ডেটার নিরাপত্তা এবং এক্সেস নিয়ন্ত্রণ পরিচালনা করতে পারবেন।
Read more